<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <!-- 
      插槽的渲染作用域：
          概念：
            插槽内容中的数据或方法是找当前组件还是找渲染到的子组件

          结论：
            找当前组件要

          总结：

            父组件模板中的表达式只能访问父组件的作用域；子组件模板中的表达式只能访问子组件的作用域。

     -->

    <div id="app"></div>

    <script src="../lib/vue3.js"></script>
    <script>
      const app = Vue.createApp({
        template: `
          <div>
            <h1>插槽</h1>

            <BaseButton>
              <span>Hello, {{ username }}</span>  
            </BaseButton>
          </div>
        `,

        data() {
          return {
            username: "张三",
          };
        },
      });

      app.component("BaseButton", {
        template: `
          <button>
            <slot />  
          </button>
        `,

        data() {
          return {
            username: "里斯",
          };
        },
      });

      app.mount("#app");
    </script>
  </body>
</html>
